W większości przykładów prawidłowego użycia schematów aktorów scala (i akka) ludzie mają tendencję do wyprowadzania każdego przekazu z jednej cechy. Na przykład: cecha wiadomości Ping obiektu rozszerza Message obiekt Pong rozszerza wiadomość Jednak zarówno w Scali, jak i Akka, odbiór wiadomości nie jest w ogóle wpisywany. Czy jest jakiś powód, aby wdrożyć wspólną cechę?
2021-01-29 08:23:55
To naprawdę zależy od tego, co próbujesz osiągnąć. Na przykład niedawno zbudowałem małą aplikację, używając aktorów, którzy mieli kilka typów aktorów, oraz aktora zarządzającego, który działał mniej więcej jak router. Teraz pracujący aktorzy mogli otrzymać wiele różnych wiadomości, na przykład Foo, Bar i Baz. Bez nadtypu w roli aktora zarządzającego musiałbym napisać coś takiego: reagować { sprawa x: Foo | x: Bar | x: Baz => pracownik! x } Co jest oczywiście niepotrzebnie gadatliwe. Więc w tym przypadku nadtyp WorkerMessage miałby dużo sensu, ponieważ upraszcza twój kod: reagować { sprawa x: WorkerMessage => pracownik! x } Z drugiej strony powoduje to, że wiadomości Foo, Bar i Baz są praktycznie bezużyteczne do innych celów niż używanie ich przez WorkerActors. Gdybyś miał na przykład komunikat Stop lub Init, prawdopodobnie byłoby to złe, ponieważ musiałbyś przedefiniować go w każdym miejscu. Więc jeśli wiesz, że będziesz mieć tylko aktorów, którzy nie przekazują wiadomości (to znaczy sami je przetwarzają), to myślę, że będzie dobrze bez nadtypu dla nich. Myślę, że powodem, dla którego ludzie robią to mniej więcej domyślnie, jest to, że jeśli później zmienisz kod, nie musisz później tworzyć cechy, ponieważ już to zrobiłeś na początku. Osobiście zawsze staram się unikać niepotrzebnych kosztów, więc prawdopodobnie nie zdefiniowałbym nadtypu, chyba że naprawdę tego potrzebuję. Poza tym naprawdę nie wiem, czy stworzenie nadtypu ma jakikolwiek wpływ na wydajność, ale ciekawie byłoby wiedzieć. | Zarówno w scala.actors (przez InputChannel [T] lub Reactor [T]), jak i Akka (TypedActor) możesz ustawić granice typów dla przychodzących wiadomości; W większości przykładów wiadomości mają charakter zapieczętowany. Dzieje się tak z 2 powodów: jeśli program obsługi komunikatów (funkcja częściowa) aktora nie obejmuje wszystkich komunikatów rozszerzających cechę, kompilator generuje ostrzeżenie; cechę zapieczętowaną można rozszerzyć tylko w pliku źródłowym, w którym cecha jest zdefiniowana, a zatem klient nie może zdefiniować własnych komunikatów rozszerzających cechę; | Nie jest to obowiązkowe, ale jest to projekt OO. Lepszym rozwiązaniem jest posiadanie abstrakcyjnego typu komunikatów domeny aplikacji. Możesz więc uzyskać korzyści związane z polimorfizmem, gdy masz do czynienia z Wiadomościami w naszym kodzie aplikacji. cecha Wiadomość Ping obiektu rozszerza Message objet Pong rozszerza wiadomość obiekt Stop Na przykład, jeśli gdzieś w swojej aplikacji masz do czynienia z wieloma wiadomościami niezależnie od ich specyficznych typów (Ping lub Pong), potraktujesz je wszystkie jako obiekty typu Message. To ma sens? Nie? | Twoja odpowiedź StackExchange.ifUsing ("editor", function () { StackExchange.using ("externalEditor", function () { StackExchange.using ("snippets", function () { StackExchange.snippets.init (); }); }); }, "fragmenty kodu"); StackExchange.ready (function () { var channelOptions = { tagi: „” .split („”), id: "1" }; initTagRenderer ("". split (""), "" .split (""), channelOptions); StackExchange.using ("externalEditor", function () { // Muszę uruchomić edytor po fragmentach, jeśli fragmenty są włączone if (StackExchange.settings.snippets.snippetsEnabled) { StackExchange.using ("snippets", function () { createEditor (); }); } else { createEditor (); } }); function createEditor () { StackExchange.prepareEditor ({ useStacksEditor: false, heartbeatType: 'answer', autoActivateHeartbeat: false, convertImagesToLinks: true, noModals: true, showLowRepImageUploadWarning: true, reputationToPostImages: 10, bindNavPrevention: prawda, przyrostek: "", imageUploader: { brandingHtml: „Obsługiwane przez \ u003ca href = \" https: //imgur.com/ \ "\ u003e \ u003csvg class = \" ikona-svg \ "width = \" 50 \ "height = \" 18 \ "viewBox = \ "0 0 50 18 \" fill = \ "none \" xmlns = \ "http: //www.w3.org/2000/svg \" \ u003e \ u003cpath d = \ "M46.1709 9.17788C46.1709 8.26454 46.2665 7,94324 47,1084 7,58816C47.4091 7,46349 47,7169 7,36433 48,0099 7,26993C48.9099 6,97997 49,672 6,73443 49,672 5,93063C49.672 5,22043 48,9832 4,61182 48,1414 4,61182C47.4335 4,61182 46,7256 4,9168,26C364,65 46,7251 4,966C3 4,9168,51 4,966,65 4,9164,65 43.1481 6.59048V11.9512C43.1481 13.2535 43.6264 13.8962 44.6595 13.8962C45.6924 13.8962 46,1709 13.2535 46,1709 11.9512V9.17788Z \ "/ \ u003e \ u003cpath d = \" M32.492 10.1419C4184184.492 1448.1709 1448.1709 41,5985 12,6954 41,5985 10,1419V6,59049C41.5985 5,28821 41,1394 4,66232 40,1061 4,66232C39.0732 4,66232 38,5948 5,28821 38,5948 6,59049V9,60062C38,5948 10,8521 38,2696 11,5455 37,0451 11,5954 10 521 35,4954 9,60062V6,59049C35,4954 5,28821 35,0173 4,66232 34,0034 4,66232C32,9703 4,66232 32,492 5,28821 32,492 6,59049V10,1419Z \ "/ \ u003e \ u003cpath fill-rule = \" evenodd \ "clip-rule = \" evenodd \ "clip-rule = \" = \ "M25.6622 17.6335C27.8049 17.6335 29.3739 16.9402 30.2537 15.6379C30.8468 14.7755 30.9615 13.5579 30.9615 11.9512V6.59049C30.9615 5.28821 30.4833 4.66231 29.4502 4.66231C28.9913 4.9105.50789C27.499 4.86533 26.7335 4.56087 25.7005 4.56087C23.1369 4.56087 21.0134 6.57349 21.0134 9.27932C21.0134 11.9852 23.003 13.913 25.3754 13.913C26.5612 13.913 27.4607 13.4902 28.1109 12.6628128134.128C28.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128.128. .1301 14.4373 27.2502 15.2321 25.777 15.2321C24.8349 15.2321 24.1352 14.9821 23.5661 14.7787C23.176 14.6393 22.8472 14.5218 22.5437 14.5218C21.7977 14.5218 21.2429 15.0123 21.2429 15.688.35.75.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.24.34.35.688.30.688.30.688. 7.09766C27.2119 7,09766 7,94324 28,0918 28,0918 27,2311 11,5116 10,6321 9.27932C28.0918 11.5116C24.9737 26,1024 11,5116 24,1317 10,6491 24,1317 9.27932Z \ „/ \ u003e \ u003cpath d = \” M16.8045 11.9512C16.8045 17,2637 13,8962 18,2965 13,2535 13.8962C19 .3298 13,8962 19,8079 13,2535 19,8079 11,9512V8.12928C19,8079 5,82936 18,4879 4,62866 16,4027 4,62866C15,1594 4,62866 14,279 4,98375 13,3609 5,88013C12,653 5,05154 11,6581 4 .62866 10,3573 4,62866C9.34336 4,62866 8,57809 4,89931 7,9466 5,5079C7,58314 4,9328 7,10506 4,66232 6,51203 4,66232C5,47873 4,66232 5,00066 5,28821 5,00066 6,59049V11,9512C5,00066 13,253597873 13,862C5,0003 13,253597873 13,862,62,62,62,53 8,053597873 13,862,862 8,08,25359783 13,862,862 8,05353 8,0535862 0232 7.58817 8.44431 6.91179 9.53458 6.91179C10.5104 6.91179 10.893 7.58817 10.893 8.94108V11.9512C10.893 13.2535 11.3711 13.8962 12.4044 13.8962C13.4375 13.8962 13.9157 13.2535 13.9157 11.9512C10.893 13.2535 11.3711 13.8962 12.4044 13.8962C13.4375 13.8962 13.9157 13.2535 13.9157 11.95 V11.9512Z \ "/ \ u003e \ u003cpath d = \" M3.31675 6,59049C3.31675 5,28821 2,83866 4,66232 1,82471 4,66232C0,791758 4,66232 0,313354 5,28821 0,313354 6,59049V11,9512C0,313354 13,25359 0,7917582 13,85,25,862 13,85358262 13,8535862 3,31675 11,9512V6,59049Z \ "/ \ u003e \ u003cpath d = \" M1,87209 0,400291C0,843612 0,400291 0 1,1159 0 1,98861C0 2,87869 0,822846 3,57676 1,87209 3,57676C2,90056 1,97676 3,7234 2,87869 3,7234 8861C3,7234 1,1159 2,90056 0,400291 1,87209 0,400291Z \ "fill = \" # 1BB76E \ "/ \ u003e \ u003c / svg \ u003e \ u003c / a \ u003e", contentPolicyHtml: "Wkład użytkowników licencjonowany na mocy \ u003ca href = \" https: //stackoverflow.com/help/licensing \ "\ u003ecc by-sa \ u003c / a \ u003e \ u003ca href = \" https://stackoverflow.com / legal / content-policy \ "\ u003e (polityka treści) \ u003c / a \ u003e", allowUrls: true }, onDemand: prawda, discardSelector: ".discard-answer" , natychmiastShowMarkdownHelp: true, enableTables: true, enableSnippets: true }); } }); Dziękujemy za przesłanie odpowiedzi na temat Stack Overflow! Pamiętaj, aby odpowiedzieć na pytanie. Podaj szczegóły i udostępnij swoje badania! Ale unikaj… Proszenie o pomoc, wyjaśnienia lub odpowiadanie na inne odpowiedzi. Wygłaszanie oświadczeń na podstawie opinii; poprzyj je referencjami lub osobistym doświadczeniem. Aby dowiedzieć się więcej, zapoznaj się z naszymi wskazówkami dotyczącymi pisania świetnych odpowiedzi. Wersja robocza zapisana Wersja robocza odrzucona Zarejestruj się lub zaloguj StackExchange.ready (function () { StackExchange.helpers.onClickDraftSave ('# login-link'); }); Zarejestruj się za pomocą Google Zarejestruj się za pomocą Facebooka Zarejestruj się przy użyciu adresu e-mail i hasła Zatwierdź Opublikuj jako gość Nazwa E-mail Wymagane, ale nigdy nie pokazywane StackExchange.ready ( function () { StackExchange.openid.initPostLogin ('. New-post-login', 'https% 3a% 2f% 2fstackoverflow.com% 2fquestions% 2f6322437% 2fshould-actor-messages-extension-a-common-trait% 23new-answer', ' question_page '); } ); Opublikuj jako gość Nazwa E-mail Wymagane, ale nigdy nie pokazywane Opublikuj swoją odpowiedź Odrzucać Klikając „Opublikuj odpowiedź”, akceptujesz nasze warunki korzystania z usługi, politykę prywatności i politykę dotyczącą plików cookie Nie szukasz odpowiedzi? Przeglądaj inne pytania otagowane jako aktor scala akka lub zadaj własne pytanie.